## Administración de memoriat

Jerarquías de memoria

Ref: Fundamentos de Sistemas Operativos



+ Capacida

Administración de memoriat

Jerarquías de memoria:

¿cómo se accede cada elemento?



#### Memoria principal (RAM)

- Arreglo de bytes.
- Originariamente los procesos la usaban directamente.
- ¿cómo soportar la multiarea?

# Memoria principal: multitarea, opción 1

 Cuando se necesita darle el procesador a otro proceso, se guarda el proceso actual en disco y se carga el nuevo proceso:



# Memoria principal: multitarea, opción 2

• Hacer que cada proceso use una región de

**RAM** 

memoria diferente:

**P3** P2 P1

## Memoria principal: multitarea Segmentación

- Agregamos hardware especializado: MMU (unidad de manejo de memoria).
- Los procesos se dividen en distintos segmentos, aparece el concepto de direcciones virtuales.
- Cada segmento comienza en una determinada posición de memoria, tiene un determinado largo y permisos.
- Los segmentos pueden ser reubicados fácilmente en la memoria (sólo hay que cambiar el comienzo del segmento).
- Si un programa no necesita más un segmento lo puede desechar.

## Memoria principal: multitarea Segmentación

 Agregamos hardware especializado: MMU (unidad de manejo de memoria)



## Un paso más allá: paginación



## Un paso más allá: paginación

- Ahora las direcciones virtuales se agrupan de a páginas.
- Cada página lógica (tamaño "estándar" 4Kb) puede corresponderse a una página (o marco) físico en memoria.
- Un proceso ve un rango alto de direcciones virtuales que puede estar mapeado a un cierto número de páginas físicas (nunca mayor al nro. de páginas físicas de la memoria principal)

### ¿cómo se realiza el mapeo?

- Las direcciones virtuales se dividen en: (nro\_de\_página\_virtual, desplazamiento)
- Se usa una tabla de paginación para mantener la relación:

```
(nro de página_virtual, nro_de_página_física)
```

## ¿cómo se realiza el mapeo?

Generalmente hay hardware especializado:



#### Paginación

- Ahora las direcciones virtuales se agrupan de a páginas.
- Cada página lógica (tamaño "estándar" 4Kb) puede corresponderse a una página (o marco) físico en memoria.
- Un proceso ve un rango alto de direcciones virtuales que puede estar mapeado a un cierto número de página físicas (nunca mayor al nro. de páginas físicas de la memoria principal).
- ¿qué pasa con las restantes?

## Mejora 1: Paginación Jerárquica



#### Mejora 2: Tablas hash



## Combinando las dos: TLB pequeño



TLB: Translation Lookaside Buffer (buffer de traducción -caché-)

## ¿paginación + segmentación?

 Se puede en algunas arquitecturas. La mayoría de los SO actuales utilizan sólo paginación.

#### Otra alternativa

• Tabla de paginación invertida

## Localidad de referencias



#### Repasemos entonces

• Jerarquía de memoria

• Esquema de memoria virtual



## ¿Quién/Cuando se organizan los segmentos y los rangos de direcciones de un proceso?

Varios



## ¿Qué pasa en i386?

• Modelo usado por el Pentium (dir. físicas 32 bits):

(linear address) page directory offset page table 12 11 22 21 4-KB page table page page directory CB3 4-MB register page page directory offset 31 22 21

# ¿Más de 4Gb de RAM?: PAE (Physical Address Extension)

Con páginas de 4 Kb



#### PAE (Physical Address Extension)

Con páginas de 2 Mb



#### x86\_64

- Usa un superset de PAE.
- Añade un nivel más de entradas
- Permite páginas de 1Gb
- ¿cuánto ocupa una tabla de paginación completa para un espacio de dirs. virtuales de 48 bits?

Algo más de 512 Gb de RAM (wikipedia)

¿cómo se soluciona? Sencillamente, no se crean las tablas que no son necesarias (huecos).